From: kfraser@localhost.localdomain Date: Tue, 17 Oct 2006 17:52:17 +0000 (+0100) Subject: [SOLARIS] Xen daemons are managed separately, so we need a way to start X-Git-Tag: archive/raspbian/4.8.0-1+rpi1~1^2~15589^2~64 X-Git-Url: https://dgit.raspbian.org/%22http:/www.example.com/cgi/%22https:/%22bookmarks://%22Dat/%22http:/www.example.com/cgi/%22https:/%22bookmarks:/%22Dat?a=commitdiff_plain;h=22241b17fed886cd535b48366b55a3e5a9d4f2e8;p=xen.git [SOLARIS] Xen daemons are managed separately, so we need a way to start just xend, and we need to disable xend's self-restarter. Signed-off-by: John Levon --- diff --git a/tools/misc/xend b/tools/misc/xend index ff58b30773..b0ee27f556 100644 --- a/tools/misc/xend +++ b/tools/misc/xend @@ -19,6 +19,9 @@ The daemon should reconnect to device control interfaces and recover its state when restarted. + + On Solaris, the daemons are SMF managed, and you should not attempt + to start xend by hand. """ import os import os.path @@ -108,9 +111,10 @@ def main(): if not sys.argv[1:]: print 'usage: %s {start|stop|restart}' % sys.argv[0] elif sys.argv[1] == 'start': - start_xenstored() - start_consoled() - start_blktapctrl() + if os.uname()[0] != "SunOS": + start_xenstored() + start_consoled() + start_blktapctrl() return daemon.start() elif sys.argv[1] == 'trace_start': start_xenstored() diff --git a/tools/python/xen/xend/osdep.py b/tools/python/xen/xend/osdep.py index 296dac4369..35af7c55af 100644 --- a/tools/python/xen/xend/osdep.py +++ b/tools/python/xen/xend/osdep.py @@ -24,4 +24,13 @@ _scripts_dir = { "SunOS": "/usr/lib/xen/scripts", } -scripts_dir = _scripts_dir.get(os.uname()[0], "/etc/xen/scripts") +_xend_autorestart = { + "Linux": True, + "SunOS": False, +} + +def _get(var, default=None): + return var.get(os.uname()[0], default) + +scripts_dir = _get(_scripts_dir, "/etc/xen/scripts") +xend_autorestart = _get(_xend_autorestart) diff --git a/tools/python/xen/xend/server/SrvDaemon.py b/tools/python/xen/xend/server/SrvDaemon.py index 3f3a90d15a..f883e7da85 100644 --- a/tools/python/xen/xend/server/SrvDaemon.py +++ b/tools/python/xen/xend/server/SrvDaemon.py @@ -17,6 +17,7 @@ import traceback import xen.lowlevel.xc from xen.xend.XendLogging import log +from xen.xend import osdep import relocate import SrvServer @@ -168,8 +169,14 @@ class Daemon: # ready to receive requests. All subsequent restarts we don't # want this behaviour, or the pipe will eventually fill up, so # we just pass None into run in subsequent cases (by clearing w - # in the parent of the first fork). + # in the parent of the first fork). On some operating systems, + # restart is managed externally, so we won't fork, and just exit. while True: + + if not osdep.xend_autorestart: + self.run(os.fdopen(w, 'w')) + break + pid = self.fork_pid() if pid: if w is not None: